home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Personal Computer World 2009 February
/
PCWFEB09.iso
/
Software
/
Resources
/
Chat & Communication
/
Digsby build 37
/
digsby_setup.exe
/
lib
/
PIL
/
IcnsImagePlugin.pyo
(
.txt
)
< prev
next >
Wrap
Python Compiled Bytecode
|
2008-10-13
|
6KB
|
191 lines
# Source Generated with Decompyle++
# File: in.pyo (Python 2.5)
import Image
import ImageFile
import string
import struct
HEADERSIZE = 8
def nextheader(fobj):
return struct.unpack('>4sI', fobj.read(HEADERSIZE))
def read_32t(fobj, .1, .2):
(start, length) = .1
(width, height) = .2
fobj.seek(start)
sig = fobj.read(4)
if sig != '\x00\x00\x00\x00':
raise SyntaxError, 'Unknown signature, expecting 0x00000000'
return read_32(fobj, (start + 4, length - 4), (width, height))
def read_32(fobj, .1, size):
(start, length) = .1
fobj.seek(start)
sizesq = size[0] * size[1]
if length == sizesq * 3:
indata = fobj.read(length)
im = Image.frombuffer('RGB', size, indata, 'raw', 'RGB', 0, 1)
else:
im = Image.new('RGB', size, None)
for band_ix in range(3):
data = []
bytesleft = sizesq
while bytesleft > 0:
byte = fobj.read(1)
if not byte:
break
byte = ord(byte)
if byte & 128:
blocksize = byte - 125
byte = fobj.read(1)
for i in range(blocksize):
data.append(byte)
else:
blocksize = byte + 1
data.append(fobj.read(blocksize))
bytesleft = bytesleft - blocksize
if bytesleft <= 0:
break
continue
if bytesleft != 0:
raise SyntaxError('Error reading %r channel [%r]' % (channel, bytesleft))
band = Image.frombuffer('L', size, string.join(data, ''), 'raw', 'L', 0, 1)
im.im.putband(band.im, band_ix)
return {
'RGB': im }
def read_mk(fobj, .1, size):
(start, length) = .1
fobj.seek(start)
band = Image.frombuffer('L', size, fobj.read(size[0] * size[1]), 'raw', 'L', 0, 1)
return {
'A': band }
class IcnsFile:
SIZES = {
(128, 128): [
('it32', read_32t),
('t8mk', read_mk)],
(48, 48): [
('ih32', read_32),
('h8mk', read_mk)],
(32, 32): [
('il32', read_32),
('l8mk', read_mk)],
(16, 16): [
('is32', read_32),
('s8mk', read_mk)] }
def __init__(self, fobj):
self.dct = dct = { }
self.fobj = fobj
(sig, filesize) = nextheader(fobj)
if sig != 'icns':
raise SyntaxError, 'not an icns file'
i = HEADERSIZE
while i < filesize:
(sig, blocksize) = nextheader(fobj)
i = i + HEADERSIZE
blocksize = blocksize - HEADERSIZE
dct[sig] = (i, blocksize)
fobj.seek(blocksize, 1)
i = i + blocksize
def itersizes(self):
sizes = []
for size, fmts in self.SIZES.items():
for fmt, reader in fmts:
if self.dct.has_key(fmt):
sizes.append(size)
break
continue
return sizes
def bestsize(self):
sizes = self.itersizes()
if not sizes:
raise SyntaxError, 'No 32bit icon resources found'
return max(sizes)
def dataforsize(self, size):
dct = { }
for code, reader in self.SIZES[size]:
desc = self.dct.get(code)
if desc is not None:
dct.update(reader(self.fobj, desc, size))
continue
return dct
def getimage(self, size = None):
if size is None:
size = self.bestsize()
channels = self.dataforsize(size)
im = channels.get('RGB').copy()
try:
im.putalpha(channels['A'])
except KeyError:
pass
return im
class IcnsImageFile(ImageFile.ImageFile):
format = 'ICNS'
format_description = 'Mac OS icns resource'
def _open(self):
self.icns = IcnsFile(self.fp)
self.mode = 'RGBA'
self.size = self.icns.bestsize()
self.info['sizes'] = self.icns.itersizes()
self.tile = ('',)
def load(self):
Image.Image.load(self)
if not self.tile:
return None
self.load_prepare()
im = self.icns.getimage(self.size)
self.im = im.im
self.mode = im.mode
self.size = im.size
self.fp = None
self.icns = None
self.tile = ()
self.load_end()
Image.register_open('ICNS', IcnsImageFile, (lambda x: x[:4] == 'icns'))
Image.register_extension('ICNS', '.icns')
if __name__ == '__main__':
import os
import sys
im = Image.open(open(sys.argv[1], 'rb'))
im.save('out.png')
os.startfile('out.png')